

27 SEP 2004

31 MAR 2003

**PRIORITY  
DOCUMENT**

SUBMITTED OR TRANSMITTED IN  
COMPLIANCE WITH RULE 17.1(a) OR (b)



**Prioritätsbescheinigung über die Einreichung  
einer Patentanmeldung**

**Aktenzeichen:** 102 13 882.6

**Anmeldetag:** 27. März 2002

**Anmelder/Inhaber:** Siemens Aktiengesellschaft,  
München/DE

**Bezeichnung:** Verfahren zur Decodierung einer mit Hilfe eines  
binären Faltungscodes verschlüsselten Datenfolge

**IPC:** H 03 M 13/39

**Die angehefteten Stücke sind eine richtige und genaue Wiedergabe der ur-  
sprünglichen Unterlagen dieser Patentanmeldung.**

München, den 27. März 2003  
Deutsches Patent- und Markenamt

Der Präsident  
Im Auftrag

Hrabinger

**Beschreibung**

Verfahren zur Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge

5

Die vorliegende Erfindung betrifft ein Verfahren zur Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge aus K Informationsbits mittels einem Max-LogMAP-Algorithmus.

10

Bei Sprachkanälen und bei Datenkanälen eines Funkkommunikationssystems, das beispielsweise nach dem GSM/EDGE-Mobilfunkstandard ausgeprägt ist, werden zur Datencodierung bzw. Da-

15 tendecodierung binäre Faltungscodes verwendet. Ein bevorzugter Algorithmus für eine sogenannte „Softinput/Softoutput-Decodierung“ ist der bekannte „symbol-by-symbol log-likelihood maximum a posteriori probability“-Algorithmus (LogMAP-Algorithmus), der im allgemeinen mit Hilfe einer Maximum-Approximation (MaxLogMAP-Algorithmus) realisiert

20 wird.

Der gründlegende MAP-Algorithmus ist beispielsweise in der Druckschrift „Optimal Decoding of Linear Codes for Minimizing Symbol Error Rate“, L.R. Bahl et al., IEEE Transactions on Information Theory, pp. 284 – 287, March 1974 beschrieben, der MaxLogMAP-Algorithmus kann der Druckschrift „Iterative Decoding of Binary Block and Convolutional Codes“, J. Hagenauer et al., IEEE Transactions on Information Theory, vol. 42, no. 2, pp. 429 – 445, March 1996 entnommen werden.

30

Ein mit Hilfe eines sogenannten „gleitenden Fensters“ (Decodierfenster) durchgeföhrter Window-MaxLogMAP-Algorithmus ist in der Druckschrift „An Intuitive Justification and a Simpli-

fied Implementation of the MAP Decoder for Convolutional Codes", A. J. Viterbi, IEEE Journal on Selected Areas in Communications, vo. 16, no.2, pp. 260 - 264, Feb. 1998, beschrieben.

5           Als Grundlage für die Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge dient das binäre Trellis-Diagramm. Ein zu einem Informationsbit der Datenfolge gehörendes Segment des Trellis-Diagramms erfasst alle möglichen Kombinationen von  $m$  (Gedächtnislänge des Faltungscodes) vorausgegangen Informationsbits als  $2^m$  Ausgangszustände. Weiterhin werden alle sich daraus ergebenden „Umrechnungen“ (Codierungen) des Informationsbits als  $2^{(m+1)}$  Zustandsübergänge und resultierende  $2^m$  Zielzustände als Ausgangszustände für das nächste nachfolgende Informationsbit erfasst. Eine Informationsbitfolge entspricht dabei einem bestimmten Pfad innerhalb des Trellis-Diagramms, wobei mit Hilfe des MaxLogMAP-Algorithmus eine Abfolge der wahrscheinlichsten Informationsbits im Trellis-Diagramm ermittelt wird.

20           Bei der Realisierung des MaxLogMAP-Algorithmus ist grundsätzlich zwischen einer systolischen Realisierung einerseits, und einer prozessor-orientierten Realisierung andererseits zu unterscheiden.  
25           Bei der systolischen Realisierung wird eine möglichst hohe Parallelität von Decodierschritten im gesamten Trellis-Diagramm angestrebt. Diese Realisierung kommt bei extrem hohen Datendurchsatz-Anforderungen von bis zu 50 Gbit/s zur Anwendung.  
30           Die prozessor-orientierte Realisierung ist bei geringem Hardwareaufwand für moderate Datendurchsatz-Anforderungen von einigen Mbit/s geeignet.

Bei beiden Realisierungen wird vorausgesetzt, dass für große, blockweise übertragene Datenfolgen eine Decodierung nur mit Hilfe eines Decodierfenster sinnvoll realisiert werden kann.

- 5 Aus Gründen des Datendurchsatzes und des Hardwareaufwands wird zur Decodierung in der Regel der Window-MaxLogMAP-Algorithmus verwendet.

Decodierungs-Ergebnisse (Softoutput-Werte), die vergleichend 10 dazu mit einem MaxLogMAP-Algorithmus ohne Decodierfenster gewonnen werden, sind zwar genauer, jedoch wird hierbei ein großer Aufwand an Hardware und an Speicher benötigt.

Eine Alternative zum MaxLogMAP-Algorithmus wird, bezogen auf 15 eine Blockfehlerrate bei einem gegebenem Signal-Rausch-Abstand, durch den in DE 39 10 739 C3 bzw. in DE 42 24 214 C2 beschriebenen „Softoutput-Viterbi-Algorithmus“ (SOVA) gebildet. Der SOVA-Algorithmus weist vergleichend zum MaxLogMAP-Algorithmus jedoch eine geringere Korrelation zwischen Deco-20 dierfehlern und gebildeten Softoutput-Werten auf.

Die Aufgabe der vorliegenden Erfindung besteht darin, eine Decodierung einer mit Hilfe eines binären Faltungscodes ver-25 schlüsselten Datenfolge mittels MaxLogMAP-Algorithmus derart durchzuführen, dass bei geringem Hardwareaufwand genaue Softoutput-Werte als Decodierungs-Ergebnisse gebildet werden.

Die Aufgabe der Erfindung wird durch die Merkmale des An-spruchs 1 gelöst. Vorteilhafte Weiterbildungen sind in den 30 Unteransprüchen angegeben.

Das erfindungsgemäße Verfahren gehört zu den prozessororien-tierten Realisierungen des MaxLogMAP-Algorithmus.

Durch die erfindungsgemäße Speicherkaskadierung einerseits und durch die Verwendung von Stützstellen zur Metrikberechnung andererseits, ist der MaxLogMAP-Algorithmus effizient 5 auf genau einem anwenderspezifischen Baustein (ASIC) integrierbar.

Durch den Verzicht auf die Verwendung eines Decodierfensters müssen keine Abstriche bei der Genauigkeit der Decodierungs-10 ergebnisse erfolgen.

Die Metrikwerte werden erfindungsgemäß bei einem ersten Berechnungsdurchgang produktiv und bei weiteren Berechnungsdurchgängen auf den abgespeicherten Stützstellen basierend 15 reproduktiv berechnet.

Durch die erfindungsgemäße Speicherkaskadierung wird ein optimaler Datendurchsatz realisiert.

20 Durch das erfindungsgemäße Verfahren wird Speicherplatz und damit Fläche auf einem ASIC-Baustein eingespart. Die eingesparte Fläche steht somit für weitere Signalverarbeitungsalgorithmen zur Verfügung, wodurch zusätzliche Algorithmen im ASIC-Baustein realisierbar sind.

25 Im folgenden wird ein Ausführungsbeispiel der Erfindung anhand einer Zeichnung näher erläutert. Dabei zeigt:

FIG 1 eine prinzipielle Darstellung eines MaxLogMAP-  
30 Algorithmus zur exakten Berechnung von Softoutput-Werten gemäß dem Stand der Technik,

FIG 2 eine prinzipielle Darstellung eines Window-MaxLogMAP-Algorithmus zur Berechnung von Softoutput-Werten gemäß dem Stand der Technik,

FIG 3 eine prinzipielle Darstellung eines erfindungsgemäßen MaxLogMAP-Algorithmus zur exakten Berechnung von Softoutput-Werten, und

FIG 4 ein Beispiel zur erfindungsgemäßen Metrikwert-Berechnung und Abspeicherung.

10 FIG 1 zeigt eine prinzipielle Darstellung eines MaxLogMAP-Algorithmus zur exakten Berechnung von Softoutput-Werten gemäß dem Stand der Technik.

Mit Hilfe des MaxLogMAP-Algorithmus wird eine Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge aus K Informationsbits durchgeführt.

Bei einem Trellis-Diagramm TREL werden an einem Trellis-Segment T1 beginnend Alfa-Metrikwerte  $\text{M}\alpha\text{-calc-store}$  für jedes einzelne Trellis-Segment TSN als logarithmische Übergangs-Wahrscheinlichkeiten berechnet und abgespeichert. Parallel dazu werden gleichzeitig an einem Trellis-Segment T2 beginnend Beta-Metrikwerte  $\text{M}\beta\text{-calc-store}$  für jedes einzelne Trellis-Segment TSN berechnet und abgespeichert.

25 Die beiden Berechnungen passieren einander an einem Trellis-Segment TSM, wobei ab diesem Zeitpunkt ein Entscheidungsprozess zur Errechnung eines Softoutputwerts durchgeführt wird, d.h. die Decodierung eines Informationsbits der Datenfolge erfolgt. Dabei werden bei einem in Vorwärtsrichtung durchgeföhrten „Forward-Decision-Process“ FDP nach dem Passieren des Trellis-Segments TSM aktuell berechnete Alfa-Metrikwerte

$\text{M}\alpha\text{-calc}$  mit den früher berechneten und abgespeicherten Beta-Metrikwerten  $\text{M}\beta\text{-calc-store}$  zur Errechnung des Softoutputwerts verwendet.

- 5 Dieser Vorgang erfolgt zeitgleich bei einem in Rückwärtsrichtung durchgeführten „Backward-Decision-Process“ BDP, bei dem aktuell berechnete Beta-Metrikwerten  $\text{M}\beta\text{-calc}$  mit den früher berechneten und abgespeicherten Alfa-Metrikwerten  $\text{M}\alpha\text{-calc-store}$  zur Errechnung des Softoutputwerts verwendet werden.

10

Im Folgenden gilt:

- K            Informationsbitanzahl,  
 s            Zustand einer Faltungscode-Decodierung,  
 m            Codegedächtnislänge,  
 15 T           benötigte Anzahl an Trellis-Segmenten,  
        mit  $T = K + m$ , und  
 $\pi$           Länge einer Einschwingphase, mit  $\pi > 5*m$

Mit einer Wortbreite  $w$  eines Metrikspeichers und unter der Annahme, dass die jeweiligen Metrikwerte normiert werden, werden für diese Realisierung des MaxLogMAP-Algorithmus zwei Metrik-Prozessoren und insgesamt  $2 \cdot K / 2 \cdot w \cdot 2^m$  Speicherplätze benötigt. Es wird ein Datendurchsatz erreicht von:

$$\frac{1}{t_{\text{segment}} \cdot 10^6} \text{ [Mbit/s]} .$$

25

Der oben genannte Parameter  $t_{\text{segment}}$  ist dabei abhängig von der zur Implementierung des Algorithmus verwendeten Baustein-Technologie (ASIC), von der Speicherarchitektur und von der beim ASIC-Baustein verwendeten Taktrate.

30

Bei terminierten Codes beginnt die jeweilige Berechnung der Metrikwerte unter der Annahme einer ungleichmäßigen Wahrscheinlichkeitsverteilung bei einem Trellis-Segment mit einem Startzustandwert („initial-state“), der eine Wahrscheinlichkeit von 100% aufweist, während alle weiteren „states“ eine Wahrscheinlichkeit von 0% aufweisen.

Bei den sogenannten „Tailbiting-Codes“ ist kein Startzustand von vornherein bekannt, weshalb eine Einschwingphase der Länge  $\pi$  für beide Richtungen eingeführt werden muss. Zugehörige Metrikwerte der Einschwingphase sind mit  $\alpha\text{-pre}$  bzw. mit  $\beta\text{-pre}$  bezeichnet.

FIG 2 zeigt eine prinzipielle Darstellung eines Window-  
MaxLogMAP-Algorithmus zur Berechnung von Softoutput-Werten  
gemäß dem Stand der Technik.

Bei langen Datenfolgen wird der Window-MaxLogMAP-Algorithmus,  
der mit Hilfe eines gleitenden Decodierfensters realisiert  
wird, verwendet. Als besonderer Vorteil des Window-MaxLogMAP-  
Algorithmus ist dessen effiziente Implementierung zu nennen.

Vergleichend mit FIG 1 werden Alfa-Metrikwerte  $\alpha\text{-calc}$  in Vorwärtsrichtung bei einem Trellis-Segment T1 beginnend exakt berechnet. Demgegenüber werden Beta-Metrikwerte  $\beta\text{-calc-1}$  eines ersten Decodierfensters DP1 bzw. Beta-Metrikwerte  $\beta\text{-calc-2}$  eines zweiten Decodierfensters DP2 geschätzt.

Erreichen die beiden Decodierfenster DP1 und DP2 den rechten Rand des Trellis-Diagramms TREL, sind alle Terminierungsinformationen vorhanden. Es werden die Beta-Metrikwerte

M $\beta$ -calc-1 bzw. M $\beta$ -calc-2 exakt berechnet und die entsprechenden Softoutput-Werte gebildet.

Metrikwerte Ma-pre, M $\beta$ -pre-1 und M $\beta$ -pre-2 werden wiederum einer Einschwingphase zugeordnet.

Der Window-MaxLogMAP-Algorithmus ist in der oben genannten Druckschrift „An Intuitive Justification and a Simplified Implementation of the MAP Decoder for Convolutional Codes“ näher beschrieben.

Bei dieser Realisierung werden bei einem mit FIG 1 vergleichbaren Datendurchsatz insgesamt  $\lceil w/\psi \rceil + 1$  Metrik-Prozessoren sowie  $(1+\theta) \cdot \psi \cdot w \cdot 2^m$  Speicherplätze benötigt.

15

Dabei ist:

$\psi$  die Anzahl an Trellis-Segmenten, für die jeweils  $2^m$  Metriken gespeichert werden,

$w$  die Größe des Decodierfensters in Trellis-Segmenten, und

$\theta \in \{0,1\}$  ein Parameter, der abhängig von der zur Implementierung des Algorithmus verwendeten Baustein-Technologie (ASIC), von der Speicherarchitektur und von der beim ASIC-Baustein verwendeten Taktrate ist.

25

Speziell bei Coderaten nahe eins (mit Hilfe von Punktierung erzeugt) hochratiger Kanäle, werden durch Verwendung des Decodierfensters jedoch nicht mehr tolerierbare Performance-Verschlechterungen verursacht.

30

FIG 3 zeigt eine prinzipielle Darstellung eines erfindungsgemäßen MaxLogMAP-Algorithmus zur exakten Berechnung von Softoutput-Werten.

5 Vergleichend mit FIG 1 werden wieder Alfa-Metrikwerte in einer Vorwärtsrichtung und Beta-Metrikwerte in einer Rückwärtsrichtung jedes Trellis-Segments TSN berechnet. Jedoch werden jetzt erfindungsgemäß nur Metrikwerte einer ausgewählten Anzahl an Trellis-Segmenten, die als Stützstellen dienen, ausgewählt und abgespeichert.

10 Die Abspeicherung erfolgt in einer bevorzugten Ausführungsform innerhalb eines in Ebenen kaskadiert aufgeteilten Speichers.

15 Im Folgenden gilt:

- m Codegedächtnislänge,
- sm „memory-length-shift“ eines Feed-Forward-Terminated-Codes (bei einem Rekursiv-Terminated-Code und bei einem Tail-Biting-Code ist  $sm = 0$ ),
- K Informationsbitanzahl,
- T benötigte Anzahl an Trellis-Segmenten,  
es gilt  $T = K + m$ ;
- $\pi$  Länge der Einschwingphase mit  $\pi > 5*m$ .
- 25  $\delta(1)$  Speichertiefe einer ersten Speicherebene SP(1) für Stützstellen einer ersten Metrikwert-Berechnung,
- $\delta(n-1)$  Speichertiefe einer  $n-1$  ten Speicherebene SP( $n-1$ ) für Stützstellen einer  $n-1$  ten Metrikwert-Berechnung, und
- 30  $\delta(n)$  Speichertiefe einer  $n$ -ten Speicherebene SP( $n$ ) für Stützstellen einer  $n-1$  ten Metrikwert-Berechnung.

Beim Trellis-Diagramm TREL werden in einem ersten Durchgang an einem Trellis-Segment T1 beginnend Alfa-Metrikwerte  $M\alpha\text{-calc}(1)$  in einer Vorwärtsrichtung FDP und an einem Trellis-Segment T2 beginnend Beta-Metrikwerte  $M\beta\text{-calc}(1)$  in einer Rückwärtsrichtung BDP für jedes einzelne der Trellis-Segmente TSN als logarithmische Übergangs-Wahrscheinlichkeiten berechnet.

Erfindungsgemäß werden jedoch jetzt aus den errechneten Metrikwerten  $M\alpha\text{-calc}(1)$  bzw.  $M\beta\text{-calc}(1)$  des ersten Durchgangs für eine Auswahl von  $K/\delta(1)$  Trellis-Segmenten, die als Stützstellen dienen, Metrikwerten  $M\alpha\text{-calc-sel}(1)$  bzw.  $M\beta\text{-calc-sel}(1)$  des ersten Durchgangs jeweils in einer ersten Speicherebene SP(1) mit einer Spechertiefe von  $\delta(1)$  abgelegt.

Bei einem zweiten Durchgang werden, basierend auf je zwei benachbarten Stützstellen des ersten Durchgangs, wiederum Metrikwerte  $M\alpha\text{-calc}(2)$  bzw.  $M\beta\text{-calc}(2)$  derjenigen Trellis-Segmente TSN berechnet, die zwischen den jeweiligen Stützstellen des ersten Durchgangs angeordnet sind.

Wie beim ersten Durchgang werden aus den errechneten Metrikwerten  $M\alpha\text{-calc}(2)$  bzw.  $M\beta\text{-calc}(2)$  des zweiten Durchgangs für eine Auswahl von  $K/\delta(1)/\delta(2)$  Trellis-Segmenten, die wiederum als Stützstellen dienen, die entsprechenden Metrikwerte  $M\alpha\text{-calc-sel}(2)$  bzw.  $M\beta\text{-calc-sel}(2)$  des zweiten Durchgangs in einer zweiten Speicherebene SP(2) mit einer Spechertiefe von  $\delta(2)$  abgelegt.

Diese auf den Stützstellen eines vorhergehenden Durchgangs basierende Metrikwert-Berechnung wird dementsprechend sowohl

in Vorwärtsrichtung als auch in Rückwärtsrichtung fortgesetzt. Dabei werden nach dem Passieren des Trellis-Segments TSM entsprechende Softoutput-Werte gebildet, wobei freiwerdende Speicherebenen entsprechend neu eingesetzt werden.

5

Der Entscheidungsprozess zur Bestimmung der Softoutputwerte erfolgt dabei wie in FIG 1 beschrieben. Die einzelnen Speicherebenen sind zueinander kaskadiert aufgebaut.

10 Nach n Durchgängen sind alle Softoutputwerte bestimmt, wobei die n-te Speicherebene eine Speichertiefe von  $\delta(n)$  mit abgespeicherten Metrikwerten von  $K/\delta(1)/\delta(2)/\dots/\delta(n)$  Trellis-Segmenten bzw. Stützstellen aufweist.

15 Vergleichend mit den in den Figuren FIG 1 bzw. FIG 2 angegebenen Datendurchsatz werden durch das erfindungsgemäße Verfahren insgesamt  $2 \cdot n$  Metrik-Prozessoren sowie

$$\left( \sum_{i=1}^n (1 + \theta_i) \cdot \delta_i \right) \cdot w \cdot 2^m \text{ Speicherplätze benötigt.}$$

Es gilt dabei:  $\prod_{i=1}^n \delta_i = K$ ,  $\theta_i \in \{0,1\}$ , in Abhängigkeit davon, wieviele ASIC-Taktzyklen für ein Trellis-Segment benötigt werden und wieviele Ports an den Speichern zur Verfügung stehen.

Anhand von existierenden Realisierungen des MaxLogMAPWindow-  
25 Algorithmus können Parameter abgeleitet und für einen Vergleich zwischen den aus FIG 1 bzw. FIG 2 bekannten, herkömmlichen Realisierungen und der erfindungsgemäßen Realisierung verwendet werden.

Die Ergebnisse sind der nachfolgenden Tabelle zu entnehmen:

|                                     | Logik<br>[Kgates] | Speicher<br>[Kbit] | „Fläche“<br>[Kgates] |
|-------------------------------------|-------------------|--------------------|----------------------|
| MaxLogMAP                           | 101               | 1080               | 2300                 |
| Window-MaxLogMAP                    | 233               | 138                | 500                  |
| speicherkaskadierte<br>Realisierung | 233               | 106                | 450                  |

- 5 Bei gleichem Datendurchsatz und ohne Abstriche bei der Genauigkeit des MaxLogMAP-Algorithmus, ermöglicht durch die Vermeidung eines Decodierfensters, wird der Hardware-Aufwand bei der erfindungsgemäßen speicherkaskadierten Realisierung um mehr als 80% gegenüber der herkömmlichen in FIG 1 beschriebenen Realisierung verringert.
- 10

Dabei wurde für diesen Vergleich vorausgesetzt:

- ein Overhead durch Softinput- und Softoutput Puffer an einer Systemschnittstelle mit  $(R^{-1} + 1) \cdot w_{soft} \cdot k \cdot a_{memory}$
- 15 wobei in der Regel  $k=K$  ist, jedoch  $k=W+((n_p - 1) * \delta)$  bei der Realisierung mit Decodierfenster sein kann; mit  $R$  als Code-Rate,  $w_{soft}$  als Wortbreite der Softwerte sowie  $a_{memory}$  als Flächeneinheit pro Speicherbit,
- 20 - ein Overhead durch Ansteuerung und Schnittstelle:  $A_{overhead}$ .
- ein Metrik-Prozessor incl. Skalierung der Registerbits:  

$$A_{viterbi}(w) \cdot f_{parallel} + 2^{(m+1)} \cdot w \cdot a_{flipflop}$$
wobei  $A_{viterbi}$  die Viterbi-Arithmetik für eine gegebene Wortbreite  $w$  und  $a_{flipflop}$  die Registerflächeneinheit pro Bit darstellen,  $f_{parallel}$  ist die Anzahl der in einem ASIC-Taktzyklus ausgeführten Butterfly-Berechnungen und kann folgende Werte annehmen:  $\{1, 2, \dots, 2^{(m-1)}\}$ ,

- eine Metrik-Wortbreite  $w = 16$ ,
- eine Softwert-Wortbreite  $w_{soft} = 8$ ,
- eine Speicherbitfläche  $a_{memory} = 2$ ,
- eine Registerbitfläche  $a_{flipflop} = 10$  Einheiten,
- 5 - ein Viterbi-Arithmetik/Butterfly  $A_{viterbi} = 12500$  Einheiten,
- ein Overhead  $A_{overhead} = 50000$  Einheiten.

Die Einheiten entsprechen einem Gatteräquivalent einer 0,18  
µm ASIC-Technologie bei einer Taktfrequenz von rund 150 MHz.

- 10 Im Folgenden werden Daten eines GSM/EDGE-Standard relevanten  
Parametersatz verglichen:
- Code-Rate  $R = 1/6$
  - Gedächtnislänge  $m = 6$
  - 15 - Blockgröße  $K = 1000$
  - Decoder-Durchsatz größer als 2 Mbit/s
  - Parallelität  $f_{parallel} = 1$

|                                                                                                                     | Konfiguration<br>(@ 2,6 Mbit/s)                                                                                                                                                                                                                                                                                                      | „Fläche“<br>[Kgates] |
|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| exakte Realisierung                                                                                                 | 2 Metrik-Prozessoren                                                                                                                                                                                                                                                                                                                 | 2250                 |
| Window - Realisierung<br>(Pfadverschmelzungslimit = 160)<br><br>Fenster auch bei Softinput- und Softoutput-Speicher | 7 Metrik-Prozessoren<br><br>(1+θ) Metrikspeicher mit δ=32, θ=1<br><br>1 Softinput und Softoutput-Speicher mit Fenster                                                                                                                                                                                                                | 480                  |
| Window - Realisierung<br>(Pfadverschmelzungslimit = 160)                                                            | 6 Metrik-Prozessoren<br><br>(1 + θ) Metrikspeicher mit δ=40, θ=1<br><br>1 Softinput und Softoutput-Speicher                                                                                                                                                                                                                          | 500                  |
| Window - Realisierung<br>(Pfadverschmelzungslimit = 160)                                                            | 5 Metrik-Prozessoren<br><br>(1+θ) Metrikspeicher mit δ=54, θ=0<br><br>1 Softinput und Softoutput-Speicher                                                                                                                                                                                                                            | 425                  |
| Speicherkaskadierte Realisierung                                                                                    | 6 Metrik-Prozessoren<br><br>2 Stützstellen-Speicher der 1. Ebene mit δ <sub>1</sub> =18;<br><br>(1+θ <sub>2</sub> )*2 Stützstellen-Speicher der 2. Ebene mit δ <sub>2</sub> =8, θ <sub>2</sub> =1;<br><br>(1+θ <sub>3</sub> )*2 Metrik-Speicher mit δ <sub>3</sub> =7, θ <sub>3</sub> =1;<br><br>1 Softinput und Softoutput-Speicher | 450                  |

|                                  | Konfiguration<br>(@ 2,6 Mbit/s)                                                                                                                                                                                                                                                              | „Fläche“<br>[Kgates] |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| Speicherkaskadierte Realisierung | 6 Metrik-Prozessoren<br>2 Stützstellen-Speicher der 1. Ebene mit $\delta_1=10$ ;<br>$(1+\theta_2)*2$ Stützstellen-Speicher der 2. Ebene mit $\delta_2=10$ , $\theta_2=0$ ;<br>$(1 + \theta_3) * 2$ Metrik-Speicher mit $\delta_3=10$ , $\theta_3=0$ ;<br>1 Softinput und Softoutput-Speicher | 400                  |

Bei UMTS (W-CDMA) und bei UTRAN TDD Faltungscodes sind für die Faltungsdecodierung folgende Parameter zu verwenden:

- 5 - Code-Rate  $R = 1/3$
- Gedächtnislänge  $m = 8$
- Maximale Blockgröße  $K = 300$
- Decoder-Durchsatz größer als 2 Mbit/s
- Parallelität  $f_{parallel} = 8$

|                                                                                  | Konfiguration<br>(@ 3.125 Mbit/s)                                                           | „Fläche“<br>[Kgates] |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------|
| exakte Realisierung                                                              | 2 Metrik-Prozessoren                                                                        | 2891                 |
| Window - Realisierung mit gleitenden Fenster auf Softinput / Softoutput Speicher | 6 Metrik-Prozessoren<br>$\delta=40$ , $\theta=1$                                            | 1848                 |
| Speicherkaskadierte Realisierung                                                 | 4 Metrik-Prozessoren<br>$\delta_1= 20$ , $\delta_2 = 15$<br>$\theta_1 = 0$ , $\theta_2 = 1$ | 1206                 |

Bei UMTS (W-CDMA) und bei UTRAN TDD Turbo Codes kommt ein MaxLogMAP-Decoder mit geringfügigen Erweiterungen als Teil der Turbo-Decodierung in Betracht. So kann auch hier die speicherkaskadierte Realisierung mit der direkten und der Fenster-Realisierung verglichen werden:

- Code-Rate  $R = 1/3$
- Gedächtnislänge  $m = 3$
- Maximale Blockgröße  $K = 5200$
- Decoder-Durchsatz größer als  $2 \text{ Mbit/s}$
- Parallelität  $f_{\text{parallel}} = 1/4$

|                                                                                                  | Konfiguration<br>(@3.125 Mbit/s)                                                                                                        | „Fläche“<br>[Kgates] |
|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| exakte Realisierung                                                                              | 2 Metrik-Prozessoren                                                                                                                    | 1727                 |
| Window - Realisierung<br>mit gleitenden Fenster<br>auch für<br>Softinput/Softoutput-<br>Speicher | 6 Metrik-Prozessoren<br>$\delta=40, \theta=1$                                                                                           | 159                  |
| Speicherkaskadierte<br>Realisierung                                                              | 8 Metrik-Prozessoren<br>$\delta_1=13; \delta_2=10, \delta_3=8, \delta_4=5$<br>$\theta_1 = 0, \theta_i = 1 \text{ für } i = \{2, 3, 4\}$ | 448                  |

FIG 4 zeigt ein Beispiel zur erfundungsgemäßen Metrikwert-Berechnung und Abspeicherung.

Bei einem ersten Durchgang D1 werden Alfa-Metrikwerte bzw.  
Beta-Metrikwerte berechnet. Von jedem sechsten Trellis-Segment TSN = 1, 7, 13, ..., 73 als Stützstelle werden je-

weils  $2^m$  berechnete Alfa-Metrikwerte in einer Speicherebene  $SP(\alpha_1)$  und jeweils  $2^m$  berechnete Beta-Metrikwerte in einer Speicherebene  $SP(\beta_1)$  abgespeichert.

- 5 In einem zweiten Durchgang D2 werden diese Metrikwerte aus den Speicherebenen  $SP(\alpha_1)$  bzw.  $SP(\beta_1)$  ausgelesen und von den zwischen den Stützstellen angeordneten Trellis-Segmenten die zugehörigen Alfa-Metrikwerte bzw. Beta-Metrikwerte exakt berechnet. Wieder wird eine entsprechende Auswahl an Trellis-  
10 Segmenten als Stützstellen getroffen und die zugehörigen Metrikwerte abgespeichert. Beispielhaft sind hier zwei Speicher-ebenen  $SP(\alpha_2)$  und  $SP(\alpha_2')$  bzw.  $SP(\beta_2)$  und  $SP(\beta_2')$  angegeben.

- In einem dritten Durchgang D3 wird von beiden Seiten her das  
15 Trellis-Segment TSM erreicht und es werden für den „Backward-Decision-Process“ aktuell berechnete  $2^m$  Beta-Metrikwerte mit abgespeicherten  $2^m$  Alfa-Metrikwerten, die im Speicher  $SP(\alpha_2)$  abgelegt sind, zur Bestimmung von Softoutput-Werten verwendet. Genauso werden für den „Forward-Decision-Process“ aktuell berechnete  $2^m$  Alfa-Metrikwerte mit abgespeicherten  $2^m$  Beta-Metrikwerten, die im Speicher  $SP(\beta_2)$  abgelegt sind, zur Bestimmung von Softoutput-Werten verwendet.  
20

- Nach insgesamt  $n=3$  Durchgängen  $D_n$  wurden alle Entscheidungs-werte  $M_{decisions}$  gebildet.  
25

## Patentansprüche

1. Verfahren zur Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge aus K Informati-  
5 onsbits,

- bei dem bei einem Trellis-Diagramm mit Trellis-Segmenten in einem ersten Durchgang für eine Vorwärtsrichtung und für eine Rückwärtsrichtung mit Hilfe eines MaxLogMAP-Algorithmus Metrikwerte von allen Trellis-Segmenten ex-  
10 akt berechnet werden,

- bei dem eine Anzahl an Trellis-Segmenten als Stützstellen des ersten Durchgangs ausgewählt und zugehörige Metrikwerte in einer ersten Speicherebene abgespeichert werden,  
15

- bei dem mit  $1 < i \leq n$  in einem i-ten Durchgang für beide Richtungen Metrikwerte von Trellis-Segmenten berechnet werden, die zwischen den Stützstellen eines i-1 ten Durchgangs angeordnet sind, wobei abgespeicherte Metrikwerte von Stützstellen des i-1 ten Durchgangs zur Berechnung der Metrikwerte des i-ten Durchgangs verwendet werden,  
20

- bei dem eine Anzahl an Trellis-Segmenten als Stützstellen des i-ten Durchgangs ausgewählt und zugehörige Metrikwerte in einer i-ten Speicherebene abgespeichert werden,  
25

- bei dem die auf den Stützstellen basierende Metrikwert-Berechnung und Abspeicherung n-mal erfolgt, bis sich die Metrikwert-Berechnung der Vorwärtsrichtung und der Rückwärtsrichtung bei einem Trellis-Segment treffen und nachfolgend ein Entscheidungsprozess zur Errechnung von Softoutput-Werten zur Decodierung durchgeführt wird.  
30

2. Verfahren nach Anspruch 1, bei dem für jeweils eine Richtung der ersten Speicherebene jeweils eine Speichertiefe von  $\delta_1$  zugewiesen wird, wobei in der ersten Speicherebene die jeweiligen Metrikwerte von jedem  $K/\delta_1$ -ten Trellis-  
5 Segment abgespeichert sind.
3. Verfahren nach Anspruch 1 oder 2, bei dem für jeweils eine Richtung der i-ten Speicherebene jeweils eine Speichertiefe von  $\delta_i$  zugewiesen wird, wobei in der i-ten Speicherebene die jeweiligen Metrikwerte von jedem  $K/\delta_1/\dots/\delta_i$  ten  
10 Trellis-Segment abgespeichert werden.
4. Verfahren nach einem der vorhergehenden Ansprüche, bei dem bei terminierten Codes für die Berechnung der Softoutput-  
15 werte eine verzögerte Entscheidungsphase verwendet wird.
5. Verfahren nach einem der vorhergehenden Ansprüche, bei dem die Decodierung auf genau einem anwenderspezifischen Bau-stein durchgeführt wird.

## Zusammenfassung

Verfahren zur Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge

5

Verfahren zur Decodierung einer mit Hilfe eines binären Faltungscodes verschlüsselten Datenfolge aus K Informationsbits mittels einem MaxLogMAP-Algorithmus. In einem ersten Berechnungsdurchgang werden Metrikwerte in einer Vorwärts- und in einer Rückwärtsrichtung bei einem Trellis-Diagramm exakt berechnet, von denen jedoch nur eine Auswahl als Stützstellen für einen weiteren Berechnungsdurchgang in einem Speicher abgelegt wird. Mit Hilfe dieser Stützstellen werden in einem weiteren Berechnungsdurchgang die zwischen den Stützstellen des ersten Berechnungsdurchgangs liegenden Metrikwerte exakt berechnet. Es werden Softoutputwerte zur Decodierung gebildet, die nach n Durchgängen alle exakt ermittelt werden.

20 FIG 3

25



FIG 2





FIG 4



**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

**BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER:** \_\_\_\_\_

**IMAGES ARE BEST AVAILABLE COPY.**

**As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.**